package sort;

public class BubbleSort {
    public static void bubbleSort(int [] arr){
        /**
         * 别忘了考虑边界啊喂！
         */
        if (arr == null || arr.length < 2) {
            return;
        }

        /**
         * i表示待安置的元素的位置，
         * 经过一轮冒泡，i上的元素就是arr[i..]中的最小值
         */
        for (int i = 0; i < arr.length; i++) {
            //将arr[i..]中的最小值引导到i上
            for (int j = arr.length-1; j > i ; j--) {
                if (arr[j]<arr[j-1]){
                    swap(arr,j,j-1);
                }
            }
        }
    }

    public static void printArray(int [] arr) {
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println();
    }

    public static void swap(int [] arr,int i,int j){
        int temp=arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }

    public static void main(String[] args) {
        int [] array = new int[]{5,6,8,9,3,6,5,3,12};
        bubbleSort(array);
        printArray(array);
    }
}
